<template>
  <div class="system-dic-container layout-padding">
    <el-card shadow="hover" class="layout-padding-auto">
      <div class="system-user-search mb15">
        <el-input v-model="state.tableData.param.search" size="default" placeholder="请输入字典名称"
                  style="max-width: 180px"></el-input>
        <el-button size="default" type="primary" class="ml10" @click="getTableData">
          <el-icon>
            <ele-Search/>
          </el-icon>
          查询
        </el-button>
        <el-button size="default" type="success" class="ml10" @click="onOpenAddDic('add')">
          <el-icon>
            <ele-FolderAdd/>
          </el-icon>
          新增字典
        </el-button>
      </div>
      <el-table :data="state.tableData.data" v-loading="state.tableData.loading" style="width: 100%">
        <el-table-column type="index" label="序号" width="60"/>
        <el-table-column prop="typeName" label="字典名称" show-overflow-tooltip></el-table-column>
        <el-table-column prop="typeCode" label="字段名" show-overflow-tooltip></el-table-column>
        <el-table-column prop="status" label="字典状态" show-overflow-tooltip>
          <template #default="scope">
            <el-tag type="success" v-if="scope.row.status">启用</el-tag>
            <el-tag type="info" v-else>禁用</el-tag>
          </template>
        </el-table-column>
        <el-table-column prop="remark" label="字典描述" show-overflow-tooltip></el-table-column>
        <el-table-column prop="createTime" label="创建时间" show-overflow-tooltip></el-table-column>
        <el-table-column label="操作" width="140">
          <template #default="scope">
            <el-button size="small" text type="primary" @click="onOpenEditDic('edit', scope.row)">修改</el-button>
            <el-button size="small" text type="primary" @click="onOpenEditDic('detail', scope.row)">详情</el-button>
            <el-button size="small" text type="primary" @click="onRowDel(scope.row)">删除</el-button>
          </template>
        </el-table-column>
      </el-table>
      <el-pagination
          @size-change="onHandleSizeChange"
          @current-change="onHandleCurrentChange"
          class="mt15"
          :pager-count="5"
          :page-sizes="[10, 20, 30]"
          v-model:current-page="state.tableData.param.pageNum"
          background
          v-model:page-size="state.tableData.param.pageSize"
          layout="total, sizes, prev, pager, next, jumper"
          :total="state.tableData.total"
      >
      </el-pagination>
    </el-card>
    <DicDialog ref="dicDialogRef" @refresh="updateOrInsert"/>
  </div>
</template>

<script setup lang="ts" name="systemDic">
import {defineAsyncComponent, onMounted, reactive, ref} from 'vue';
import {ElMessage, ElMessageBox} from 'element-plus';
import {systemDictApi} from "/@/api/system/dict";

// 引入组件
const DicDialog = defineAsyncComponent(() => import('/@/views/system/dic/dialog.vue'));

// 定义变量内容
const dicDialogRef = ref();
const state = reactive<SysDicState>({
  tableData: {
    data: [],
    total: 0,
    loading: false,
    param: {
      pageNum: 1,
      pageSize: 10,
      search: ''
    },
  }
});
// const dialogData = reactive<>({
//   typeName: '', // 字典名称
//   typeCode: '', // 字段名
//   status: true, // 字典状态
//   list: [] as ListType[], // 子集字段 + 属性值
//   describe: '', // 字典描述
// });

// 初始化表格数据
const getTableData = () => {
  state.tableData.loading = true;
  // const data = [];
  // for (let i = 0; i < 2; i++) {
  // 	data.push({
  // 		dicName: i === 0 ? '角色标识' : '用户性别',
  // 		fieldName: i === 0 ? 'SYS_ROLE' : 'SYS_UERINFO',
  // 		describe: i === 0 ? '这是角色字典' : '这是用户性别字典',
  // 		status: true,
  // 		createTime: new Date().toLocaleString(),
  // 		list: [],
  // 	});
  // }
  systemDictApi().getDictPage(state.tableData.param).then((res) => {
    state.tableData.data = res.data.records;
    state.tableData.total = res.data.total;
  })
  setTimeout(() => {
    state.tableData.loading = false;
  }, 500);
};
// 打开新增字典弹窗
const onOpenAddDic = (type: string) => {
  dicDialogRef.value.openDialog(type);
};
// 打开修改字典弹窗
const onOpenEditDic = (type: string, row: RowDicType) => {
  dicDialogRef.value.openDialog(type, row);
};
// 删除字典
const onRowDel = (row: RowDicType) => {
  ElMessageBox.confirm(`此操作将永久删除字典名称：“${row.typeName}”，是否继续?`, '提示', {
    confirmButtonText: '确认',
    cancelButtonText: '取消',
    type: 'warning',
  })
      .then(() => {
        systemDictApi().delDict(row.id).then(() => {
          getTableData();
          ElMessage.success('删除成功');
        })
      })
      .catch(() => {
      });
};
// 分页改变
const onHandleSizeChange = (val: number) => {
  state.tableData.param.pageSize = val;
  getTableData();
};
// 分页改变
const onHandleCurrentChange = (val: number) => {
  state.tableData.param.pageNum = val;
  getTableData();
};
const updateOrInsert = (data) => {
  systemDictApi().addOrUpdateDict(data).then(() => {
    getTableData();
  })
};
// 页面加载时
onMounted(() => {
  getTableData();
});
</script>
